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ABSTRACT: 

An apparatus and the method for upgrading the firmware code of an optical disk drive via the 
ATA/IDE interface are disclosed. The optical disk drive has a firmware code memory and a 
microcontroller that executes the firmware code. A drive decoder decodes to connect the optical 
disk drive to a host computer system via the ATA/IDE interface. The apparatus includes a 
programming controller that receives signals from the ATA/IDE interface and performs 
input/output decode to determine whether the host computer system has requested an upgrade 
of the firmware or to maintain the optical disk drive in normal operation. A multiplexer has a first 
Input connected to the programming controller, and the second input connected to the 
microcontroller. The multiplexer selects the first input to the memory device via the multiplexed 
output for performing a firmware upgrade operation when the host computer system requests a 
firmware upgrade. The on-site upgrade operation can be performed without access to the inside 
of the drive unit. 
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immi) ATA/IDE-fy^'-7x-;?.^^L 

^t'JrV>M;!.i:. mie7 7-A'>xra-HS:l|ffL 
T Bifie Vy^ 7't J: l.|ine3t^T ^ :^ ^ m(r)T^ -tr;^ 
ii^^$r$iJffltl>7^^'nayhD-7t. lulSATA/ 

I DE-f y5'-7x-;iS::rt-L-ci?ie3K^f >f H7 
7'S:*;^> h ay b'j.-:^' i^^TMzimtltztb<r>T 

lufSATA/ 1 DE'f y^'-7i-;^*>f>l-ti&S^ 

mi&t/m2coA:'], m/izmittaiimmimiR 

7T-A'>XTc7)77 7'7V-HargSLJtt#(C. 7 
T-A'>xrr-y7y^-Fi)flHSrff^/iJ^lC, BiifE^ 
S^tai^lS:^ tT fiia® 1 c?)A:^arMiS^t 'J r'A"^ X 

[fi*Jl2] ATA/I DE-fy:?-7x-;^^^L 
TTfe^t' ;^ K ^ 7'ffliO 7r-A'>xT3-H$rr 

•y7n^-H-t.2.ii*fliogat;iii>T, Huiern^' 

MeATA/ 1 DE^ y^-7x-XA>f>«-^^Sfl 
lulS*;^ hay fj2.-:?vXTA*»7 r-A'^xrcor 

luie*;^ h 3 y f X- -yxrhify r -A'^xr or 

flS^-fi^k HulEm 2 ^--7';l^-t k Itrie A T A/ 
I DE>f y^'-7x-x*>^>«j^f(5-ri.li-tkS:^fi 

tieATA/I DE^y^'-7x-;^±c7)|5|ej^f5 
^7 Kb;^fi-t5r4^tl.7 H^>?.rn/7A^ ^>-r 



BUia*X h 3 yh'j.-:?i-XTA*>'7 7-A '>X7CD7 
^l:=^-t|-f kluteSSt^-f 7';Uffi-f tBirieATA/ 

I DE-^y^'-7x-;^*>^,coWJBtl.fi-ti:S-gm 
MBATA/I DE-^y:?-7x-;?.±comieWJ5i5 

tsfi^5:7 7f-LT, tm^'evr^u xmmrjL 

Buie^^x h ay tx-^'>';^TA*57 r-A'>x7(?)7 
77-/U- y^^m^ifzt^ , BuiE77r/ix- K^uflS 

^l:^-fi^i:lulEI^4<^'f ^— Jim tmi AT A/ 
I DE-fy^'-7x-;^*^4>co«i5tl.fi^k$gfi 

^$iJfflifi-t^4^tSSiJfflirn^7A>f ^f^-r/P^ vi- 

imm3] ATA/IDE>fy^-7x-;:^«>M 
•r3t^T -f 7'fflW7r-A'>x73-KI'7 

77°/^- ¥tim^m2<^m^zii\.^x. 

BulB*;?. h a y ex-^'>';^rA3&i7 r-A^x7c07 
77-/U-H^S*l/it^. KfiE7HUxro^^7A 

^^-T'yl'^ 7 J; o tSft? ix/im£A T A/ 1 D 
E^y:?-7x-x*>^>£7)WJSt■l.^i-^{i. K^SAta 

/ 1 D E ^ y ^^-7 X -XCOMH 6 f 7 h i^7 h' l'^ 

[11*554] ATA/IDE'<y^-7x-:^^^L 
•C?K^f -f h'^^ 7'fflc7)7 T-A'^x73- h"$-7 
77'^^k- H1-SilSJl2cO|ia(CjDUT. 
mf^*::^ h- ayh'jL-^'>':^rA*57 r-A'>xTc07 
77°/!^- H&S*L/ik # , mier-^rn^^^A-f 
^^-nUy 7f-ti; oT^fiS^lJtMeAT A/ I D E 

I DE'f y:J'-7x-;^<5Df-^'ii-f-^i!'-^:< kiTfi 

8h'7 hx'hhcibirmttimm, 

[»*JS5] ATA/\DE^y9-7x-X^i\L 

',ryv- K-rsii*ia2<?^atct5i^T. 

mlB:!;;^ h ay tx-^'>';^TA*57 r-2>.'^JL7<n7 

-r/i^? 7-?-tzj:-?rgfi$ii/^KiieATA/ 1 DE-^ 

y:?-7x-;^*»^>i^*tKtl.fi-t{4. lulEATA/I 
DE'f y^-y s.-xff)r~9m^(ryy^£< t fcTffiS 
t'7 ht'l>-l.^:t5:!^Sktl.gS, 
[if*Ji6] ATA/I DE-f y:?-7x-;^^:n-L 
X^f^ X9 Yy^ /fflc7)7 r-A>>x7a-h'Sr7 

t\Wt^f ^x^YyA-/\x. CX>-KQ>mYy^:fX: 

mmj\ ATA/\\yE^y9-7y,-X^i^L 
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^t'JfAM;?.t. frf£7T-i:>'>xr3-HSr^^fL 
m^^mmh-^A9u^yyn-yt. luiHATA/ 

BUtaATA/ I D E>f y^'-7x-X*><i>fi^^^fi 
f j.-rJ' v'XTA*iHufE7 7 -A-^xr^OT v7°^'V- 

m 1 m% 2 oA:»3 1 , mitmumm^mmx^ 

ayh a-y^zmm^ti. ^ Lxmi§'mi\M«ixm 
miru^y 5 yy^ ^'-T'/Wi-t&Sfi-ri.^M-fk^ 

luieATA/ 1 D E-^ y;J'-7x-X*>^>f|-^S:Sfi 

luffi^i^;^ h a yt° J.-:? v-;^fA*>'7 r-A'>x7<?)7 
•y7-^^-K^g$L;tkl!. l?riElgliO^;^-7';Hi 
^tlwIEATA/ 1 DE'f y^'-7x-;?>*>4.o^;Et 

MB*;^ h a y t i-^' i'XTA*>'7 r -A'^xror 

•y 7-/lx- H $r^^ L/C t # , mlBT 7 T/l^- FM8 
\\L^-m^tmiW,2<D^ ^>-7-;U^l^fc BUlBATA/ 
I DE^y:5'-7x-XA^^>c?)«J6-tl.fi-ttS:^fi 
L, mlBATA/i DE>f y^'-7x-;^±c7)HJilfiitl^ 

-thmn^y -'/^Lx. mi^^^)'fju xm(r>mt^^ 

}Vy-/^t. 

m^it-x y a y fa-;? vxr A7!»«7 T -K^:trr(rrr 
7 ry\y- H ^git^ L7t t ^ . B?iBT 7 y^v- YW^ 
'^c^-\%^hm%^m^<^^ 7Vi^-f t buIbata/ 

I DE'f y^-7x-X*^A,(7)W^-r'Sfl-^t^gfi 



B?iBATA/I DE^y:?-7x-;^±Oluiek^lS 
7i.r-^^^^m.th9-9y'c^i^yM ^^-rjly 

BUlB^T. h ay t°jL-:5'i^y^rAAi7 T-A'^XTCOT 
7 7ru- H SrS« L/C t # , MIBT 77°i?V- Y^m 

I DE^yi?-7x-XA^/^>cOWJDtl.fi-^i:Sr,gli 
L, MIBATA/I DE-f y^'-7x-;^±^0Mfi)i^Ji5 

^»JfflHi-t^^"ri.SiJSIirn/7A>f ^t^-T'yk^ 7^ 

[il*:S9] ATA/I DE>fy:?-7x-;?.S-^t 
Ximr^X^YyA7m(^7 7-J^^:J^7o-Y^:7 

mlB*X h -3 ye^-^ vXrAA>'7 r-J^^x.Tcr)7 
F&S^t/tt § , mlBT Kl^xrn/^A 
T'^P'^ -y^tcJ: -:> tSfi^ix/cmfieATA/ 1 D 
E-f y^-7x-;^*>ii,<^*fJf;tSft#{4. lineATA 

/ 1 D E y - 7 X -XCO^H- 1 6 f 7 h <07 H UX 

[M^JaiO] ATA/I DE'f yr?-7x-7.5::n■ 
Lt"3l^^T -f ^' b' 7 7'ffl<?5 7 r - A '^^x 7 3 - b' ^ 
777'i/P- H^l.if*fl80gati5»r^t . 
|filB*x h ay fa -^'^•;^tA*>*7 r-A»:7X7c7)7 
7 7-^'V- K L ?t: t # , fi IBt - rn / 7 A-Y 
:^-7';l^^ •yf-twJ:-?TSfi$ii!t1>nBATA/ 1 DE 
Ay-^-y ^-xi!^ty<r)nm-h\mM. lulBATA/ 
I DE'<y^'-7x-X(r)r-^'fi-^c7)^>^:<tt,Tfii 

\mm.\\\ ATA/iDE-<y^-7x>-;^€-y)- 
LT3t^T ^ K 5 7ffl(307 r-A'>x73- HS: 

Mfi4:^ h ayh°jL-^'i^;?.f A*i7 r-A'>x7<7)7 

7 7^1^- H ^-m. fc # . ffiesiifflirD A>f J^ 

-7>7 V J; -:.-Cgfi$il/c mIBAT A/ 1 D E ^ 

y^-7 -L-xt^t^(nnmfh'm^\t. IuIBata/i 

DE>f y:J'_7x-;?.c?)T-^'m^c7)^-^< i: tTfiS 

[i»*3ll2] ATA/I DE'fy^-7x-;?.$r:n- 
LT3K^T -f H 7"ffl<7)7 r-A'>x73- HSr 
777-/^- K-tl.iS*«8c7)^M{Cfel^-C. 
mfie3t^T-f;^^H7-f7'(±, CD-ROM K7-f 7"?:' 

[if«JSl3] ATA/I DE>f y^-7x-XSr:fr 
LT5ld^T <X^' 7'ffl<3D7 r-A'>x7a-H5- 

rvy^v-Y'^hmm.^<r>^mzii\\x . 

m&mT'iX^YyA'fM. DVDH7^yTibl.C: 
[11*^14] ATA/I DE'f y^-7x-X$r^^ 
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t tfrie H 5 i sffiBJt^f -f ^' i^s<07 

KflETtf^T-fX^ iiiEATA/l DE'fy 

BUl2ATA/IDE-Y>':?-7x-X$:Bgld;< 
^ ^ i; f xtEtg##3i=i^C t J; !> 7 T-A'^x 

77 y.7"^'i/-h'ii{toiiff^i^$t. -eLTfne*^ 

iiSilf^S-^^t^t^t, frflE"7-^^'n3yho-7 

immi5] ATA/I DE^y^-7x-;^^^ 
tralS^T X^ rffl607 r-A'^X73- 

mi^^T^x^ry^ya. cD-ROMF^-frT' 

[il*Jll6] ATA/IDE'fy:?-7x-:;^^:n- 
ttit^f -fXi? f<5-f7ffl<^7T-A'>X73-HS: 

7-yT:?^U-K-ri.il«3Sl 4coi«t:fcV^'C, 
ME^K^T >f K 7^ 7{4, D V D H 7^ y'x% I Z 

[11*517 3 ATA/IDE>fy^-7x-XSr:n' 
iX^^f^y.^ h'7-^7'fflc7)7r-A'^x7a-KSr 
TyrVU-¥ti>imx%->X. mtimf^X^Y 
yA7{t. BiiiE7r-i>.'^x73-Klr7,h7tl)!tft 
<r>;<^^)irf'^^Xt. H!iE7 7-i^'>x73-K^^ 
LT fiilE F 7 7'lc J; S l5iE7fe^T -f X rtSi07 ? -b 
;^»{'^$r^Jffll-tl.-?'f ^'nnyhn-^fc, huISATA 
/I DE-^ y^'-7x-X^:rt-LTBifie3t^r X^' h' 

% 1 oA:']{±r n s y ^ 3 y h d- g 

fi. miEm2<^A;'H4|fiE-?>fi?n3yhn-7{c^ 

m^z.mthmlir'O'fy 5 y/3y hn-7#gt 

rolErn^^Sy^^nybo-^^SA^ lulEATA/ 



iDE>fy:?-7x-;^*»£>^^i&SfiL.. -eUTA:*! 
/ai:'5T3 - K S-ffo T filE*^ h 3 y t ^ i/Xr 
A>{)>'ffiE7 r-A'^X7c07-y7°^?'U— KSrS^LTU 

•thzk -kmi\x\^hifi^m.-^hru^y s y/^ 

^s^l:^tRA:']^*ti.H?ie^s-ft^s*\ wiEro^' 

7 $ *-7";Pfl-f $rSfi t . iulE*A h ay tr^ 
-^^ j^;^TA^|i7 r-A'>X7<507 -y r^U— H Srg* 
Uct^, fiiElllOA^i5r|tiE^fi-fl:ai:^7^^fCfr 
lE^ ^ tVn^ Xt^^OSi. |,Xt -y 7-^ |> ^ t ^ 

[^^51 8] ATA/IDE-<y^-7x-X^:fr 
LTit^T -f X ^' F 5 ^ rffl(07 r-A'>X73- HS- 

7>yri/u-H-ri,lfSfli7io:^acjDV^T. mtr 
nfy 5 y^''3y hn-^^^'H5IE7°o^"7 S y/^ 
^^-7';Hi#&4J^K•fl. XT -y r*<j|C. 
filfiro^- 7 S y^/n y n p-^^gt^A^i/aj^ir 3 
ffiEATA/i DE>f y^-yx-xt^^mn 
Sr^ftL. ^lXA:n/iii:hr^-Y^n->xrvyy 

Sl^l|4 co>f *-7';Pfi^5:4Jife1-|.XT 7 y't . 
mSirn^y S y/n yha-ymi(^WSiit^-^ 
-yjla >^ 7 1? tiK W\iit^x h 3 y t a - ^' v-Xt Aj^i 
7r-An'X7C07-yr/V-h'^g*L^i:#, mii 
W.l<r>^ ^-7'/Wi^tBiriEATA/IDE>f y^'-7 
x-X*^^, CO^^iiSt I. t ^Sft LT 7 7 7':/l/- K 

y^a y F n-7^S<:07 H UXTo^' 7 A^ 
5'yf-*^. l>fiBi^xb3ytr3.-^'vXrA*J7r-A 

•>X7<07-yT;/^-K^W*Litt&, miiE7-y7°/ 
l^- t IfilEm 2 (7)^ ;t^-7;Hl^t fi 

lEATA/I DE>f y^'-7x-X>&^^>(0m>-ri)fi-^ 
tS-^flL, BillEATA/IDE^y^-7x-X±<^ 

<7)S#S:^7.H UXfi-^Sr^tl.XT7ri: . 
B5t£7"D/7 S y/3 y hD-7#S'7)T-^'7°0/7 

A>f :^-7'yl'7yf-**, BirE^XFaybra-rJ'vXT 
A*»'7 r-A';?x7i7)7yT/l/- h'$rS*Uo t # . 
Hi]iE7 -vr^V- H WL^-ft^i: fiism Sco-f 4s- 
r/HS-^t iflEAT A/ 1 D E ^ y 7 X -x*^^,« 
**Jotl.m-^i:5-S«L. BuieATA/l DE^y:?- 
7x-xJi(7)Hf|fSMiE-ri>il-^?:7 7^LT. mflE^t 
U TA'^ xffl(7>t#a;^'f-:J'fi-^^4fiK-ri)Xr -yr 

miir^^y 5. y^3 y hn-7^Sc5D^®7'o^^7A 
-f^s-T-zp^-yf-:;!^^ iulB*xhayfjL-^'i/XrA 
*<7r-A'>x7i7)77 7'/P-H^g$L!ti:^. fl 

iE7yri5'p- H^^b#-^i-^fc|iriEli4i7)^ ^^-y 

t miaATA/ I DE>f y:J'-7x-X*>ii,<7)*r 
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Cft^JS19] ATA/IDE'f y:$'-7x-X&^ 
LTTte^r ^ ^ ^ H 7 >f /ffli07 r -i^ -^xr 3 - H S: 

^ ^-nv^ -y f-CJ: oTSfiSiifcfiieATA/ 1 D 

/IDE-^y;?-7x-X(7)-^H-l 6t'7 htOTKU-X 

[11*31201 ATA/IDE^y^-7x-7.5-:n' 

L-C3t^r'f;^^' F7-^7'fflc7)7T-A'>xr3-H€: 
T-y7°^I/-Ktl.lH3t<:iai 8c7)^atijV^-C, 
lulB*;^ h 3 J.-:? v;?.f A*^'7 T -i^'^xT^or 
•y7°^^W-Hi&S*L^i:#, mtr—^ruyyA^ 
7';u 7 -y f-t; j; -> -C Sfi § ^i^.*iri2 A T A/ 1 D E 
-f >:J'-7x-X*>A,c7)*^j£tl>ft-t{i. lyifiATA/ 

I DE>f y^-y s.-x(r)'f—^imco'})'^j:<tijT^ 

[li*Jl2 1] ATA/I DE-^y^-7x-X^^ 
LXm^f^x:/ F7^yffl<7)7T-A'^x73-h'Sr 

r-yr/i^-Ht 1.1**111 8(7):6-at:*>v^t, 

«yT;/V-HSrS*t/ti: # , fiE®ifflITniy^A-< 
-7'/U7 7^t:J; -5TSfi§tlitB«ISATA/ 1 D E-f 
y^-7x-7.*^<b(0M£'-ri.fi-§-(i. liildATA/I 

[11*^22] ATA/I DE^y^-7x-X&^ 
LX%^r^X^ F7^7ffl«7r-A'^x73-F5: 

mi3t^f>iX^VyA:r\,t^ CD-ROM H^^fT"-? 

mt.^23\ ATA/IDE^y^'-7x-X^:fr 

r-yr/l^-H-r-Slf^^Sl 8^7):^ffi^:iiV^T. 

{Wm2A\ ATA/IDE'fy^-7x-X$:^ 
LX%^y' 4 X^ Yy^:fm<^yr-M.'^J^7^-Y^ 
T-yy-^U-Ytimxh^X , mE^^T^X^Y 
y^yu. mUy 7~J^'y:L7o~Y^Xh7thtzi^ 
<r)^^Or^<-(xt. 1ifi27r-A'>xT3-KS:||ff 
mis H 7 >f T^tc J: l>fiia3t^T -f :^ ^'rt^<07 ^' -t 
xmmVmth-7A ^uziyhu-y h . WIEATA 
/iY)EAy-^-yj,-xmLXmU%^f^x9Y 
y^ y^:t^XYay}^x-:}'i^XTAI>z^mtltzib(0 



r:i-Y^ti>Yy-iyr:i-yt. mmm2ff)A 
ix, ifie®2cOA:^{iBuiev-f^'o3yh-n-7tg?^ 

mzrxoi^yiy^zjyYo-ym^, tyf£ATA/ 
IDE'fy:?-7x-7.*>^ft-t^SftL. fLTA^ 

J^miiy 7-J^^X7C0T'yrf^]y-Yi:^1^lX^^ 

Ltztt. mi^K^x^^-mmm-n^itLxm 

mUru^'y 5 y^'W /;HI^S:4J^c-r S^^r 7 7° 

-ifiiK irlEATA/i DE-^y^'-7x-x*>/;>fi^ 
sy^W^^-7•;^^i■^^4^t, Mii^i. S2, 

miirv^y 5 y;7'3 y h n-^¥S(^lU»i-fL^— < 
-7';l-ui;7 ^iiK miit^x h 3 y tf j.-^ vXrJ:.ti^ 
7T-A'>X7c7)77r^'V-K$:g*LittS. MIB 
||liO-^4'-7';l/f|^}:HyiaATA/I DE^ y^'-7 

x-x*^^>c7)«js-ri) fi^fc $-SfiLt 77 7-/U- K 
Buiera^ 7 s y^'a y h □-7¥g<7)7 h' \yxy'uy 

yM:^-y)Vy'vi-i>K Ml-A^XY^ay^ x-^i/X 
tA*>7 r -h,-^x.7(r)7 7 r^L— F ^S^L;'^ h 

% , frier 7 r^v- ywmc^ -mtmm, 2<o^ 

^- 7'; Wt-t t lilie A TA/IDE>fy:$'-7x-X3t)> 
^>«7)W*5-ri.fi-^J:S:SfiL. fiiEATA/ 1 DE>f y 
:?-7x-X±«E#itJSEtl.fI-^^7 7f-L-C. l9iB 

■r7ri:. 

Buiero/7 s y/3yhp-7#s<^T- ^7-0/7 
A>f ;t>-7';l/9 7^*<. b3E*;^ h 3 y i/X-f 

A*J7 7 - A'>X7c07 77-/V- h'^g* Uc t ^ , 
HulET 7 7'^V- H*l3W€^-<i-t t tulEm 3 (0^ ^- 
T^^HI-^t fflEAT A/ 1 D E y ^'-7 x -Xt^t:>(ry 

«)E1-Sm-ffcS:SfiL. mfEATA/IDE>f y^- 

7i-x±(7)BufEWlEt.?.fi#Sr7 7f-tT, MIB^t 
•J taM jA^^r- :?ii-^$-4f£t l> XT 7 7° 

i:. 
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fflEAT A/ 1 D E y^-y x-xi)^t^m 

l^tm^b^^iiL. MieATA/I DE>f ^^^-7 
[fS*JS2 5] ATA/I DE-<y^-7x-X^^ 

•v7n^-h'$:g*L/Si:l= , flier H1^7>7'D/9i. 

;t^-7'/l'7 -yi-izX -yX^ii^tltimiZATA/ 1 D 
E-fy^'-7x-X*>/i>C0>FrjEt'5.fi-?ii. fflBATA 
/I DE>f y^'-7i-:^<0-^fH 6h'>y hiOTFU;^ 

CI«*3I2 6] ATA/I DE^y^-7x-X^:n' 
Lt3l£^r-fXiJ' h'7-^7ffl<07r-A'>x73-HS: 
7-y r/k- Htl.ft*«2 4 c^aCiSV^t , 
use*;?, h 3 y ta-:? i^;^TA*«7 7 -A'>X707 

;r^-7'/U7 7^twJ;->T^tiStL/::BUi2ATA/I DE 

IDE>fy:?-7x -;^<?)T- rS'fi-tOii^^r < i Tfi 

8 t'-y hT'J>l. ^ k ^l^k tl.g^. 
[if*«27] ATA/I DE^y:5'-7x-Xj^ 
LT3t?T>(X:J' H^-f 7'fflc7)7T-A'>X73-KS: 
7>y 7-/U- Htl.il*3a 2 4 iO^r&tCiJV^T , 
luie^tX h ay fa-;?>-XTJU*i7 r-A'>X7c7)7 

-y'fUy -yi-tiZX oTSfi^fl/tfiieATA/ I D E^ 
y^'-7x-;^*»<c>C0Mf5tS<i-^(4> HfliaATA/I 
D E y:5'-7 X -;^<7)T-^'^I-^Oi!'-^r< t tTfi[8 

lft*JS28] ATA/I DE^ y:?-7x-7>^:n' 

7 -y 7/W- H-r 1,11 ^JB 2 4 O^rffitiiV . 
flfS3lcf:T'f;?.:^' h'7^7{4. CD-ROM h'^-f 7t' 

[fII*)S2 91 ATA/IDE>f y:?-7x-;^^:n- 

Lt^t^T^X^' F7^7fflc07r-A'>x73-K2: 
7 77-/^- H-r-l.il^fl2 4 c7):trat::i3V^T , 
Mia^lc^r-fT.^ K7^7i4, DVD 7T'S>SC 

[ooon 



WtS. m^z. WJii. 7K^r-f;f.^K7^7ffli7)^ 

St. -?-mc*tJ55tT*7,h3yt"a-^'v-XrACiOA 
TA/IDE^y^-7x-7.SrSiUc7r-A'^x 

73- H<07 -y r^^U- h'Sr^SgCtl.:^{::ratl. . 
[0002] 

->7.T A(Zij'^^< 1 1 1 i a {c=a:-9 1 

I), ^^-y■t/^^yeJL-^<o•ttt:^T1i. cd-rom 

YyAzfffiWLmi. ato>^>CD-ROMT-f;^i7±iO 

7^'K7^7t»*Wt:|5l«t'J)l.. «I(^acoCD7r 

ft. ■• CD-ROM" }imitlh, L*»L^*i(?>. Sflf 
tia^^lS C D - R OM3&>^>{4^4(0t- ^'3&*7^-fe 

[0003] CD-R0MJ4. I SOi.zXr.Xrvi' )V 

f-mmm^i,z%miix\.^^t)\ ^«^t-^o 

'^X.7mm(nTX\ CD -ROM F^-^ 714, CD 7 

T 5 ^)-(nim.(n^-\r(r>T^p^9<r)7i^-^Mzijmi 
[00041 mjf. A'-vt/i'3ytjL-:5'i';^TJU 

X'\i. C D - R O M H ^ 7(4 L {f L \iWk<r) 0 071^ 

^ LT . mzm 1 w<7)c D . mh^'Mc D cieii 

mcii<mX<rmz^ 7r5'J-tCh'T^CD (VC 
D) (7)J:p^7*--7 7 h*<ti3SLTV^|,, fa!3ftWN- 
yt;i'nyeA-:J'fflCD-R0MK7^7{4. vcD 
h'r^rn 7 i:. $r 3 y f i - <7)aS^Bffl±HS^T- 
^SJ:atigS-$iiTV>|,. MPEG-i{cfi5ffl$ixyi 
iIt<7)^lltCct-5T. VCDSJgJifc^^irjaffl^^^ftT' 
(4=5:< , f LT 2ocr)l^<it§ik^^;U-7*i-fijfifi^' 

[0005] :Lmmtz^j:T-nm(r)yif-'7 -y ft- 

?r Hft-f ^ MPEG- 2S2PHS 0'< C D 7 r 5 U 

ir/::^r^y^N*-t'J>s. DVD {T'J^iv\LT^f^x 

^)mmi}m^^iXX\^i>tz»y. CD-R0M7*-V 
7 Hzmhimm^yh K7^7of|^c=5rv7ri. 

^^^:?^7^w«•r-g.^mtt3&^m$^lT^r^^. ^ 

ttiltf. iil*»^>^$*lSDVDH7'f7{4, 
T7t;PFDVDfc:Sn;tT, CD-R0M$-MAffil)C: 

ht^mx'hh, 

[0006] AKtT. 3yfa-:?>-7TAi?)3fe^3 
yv^iJ'hT-f:^^' (CD) ■9-7V7rAi: LT, CD- 
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iHi. M^<7)x8 6K-X(r, i BMSJgtST'fi, V 7 h 

M , 7'V>f A' 7 ^ C Dtfz^i t r'^r C D A^(i>£7)T- 7 

^'fA'ti. ^fl<jCCD-R0MK7-f7'<?)Si|ffll>'Xx 

A(;j3(tl.A- F '^X7U''<./l'C7)|lJfflirni?'7A^ii<7) 
i:±SI5lcS^$iitv^l.. ^c7)7r-i»'>xrrD^^7 

tg^rra/7V7';l^tlJU$ffl^^li (EPROM) 

'J (EEPROM) |*l(c;5.h7$^l.. 
[0 0 0 7] Cc07r-A'>X7t::S'5#, CD-RO 
M H 7 7'{±*X h 3 y ta-^ j^XTA:J)>^>0JWprig 

tZ/Xti C D - R O M r- ^' K ^ ^ ^ ^(TimmmiX't 

7h'^x77"D/7A{^, K7>f A'-^coi>fO<7)0Ifflifl;^ 
IsIS#F^c7)7 7-A':7X7i:-J)n. :t'*<^-T -f y^/v-X 

'<P— r -f yyi^X'rJ^VKjV/ry'^) ^r->- 3 y ixAL 
H ttz^^\i. ^<?)i^(d4C D - RO 

MH7-<7'Sr<5f^%l^ii*-ft3tgftr. t^'L'S:*^'^). 

mzLX MK^^mif' CD-ROM F^-<7'c7)7t-A 

'^x7{c4t;^^*i-&(±, y7h'>x7coiga{4^^jse<j 

[00083 H7-fA'7r-i^'>x7!&»'M'?> 
*>C07'Oi5^7A±W^?'^rLTl^l.^-^{4. 
^ U b 7$:h/c 7 r-A'>x7{47 -y 7°7'1/- H 

(upgrade) . f!P*>^lii0*V^ffiO3 f-tCj:-oTg# 
«it^>*i'S:t-)ti.{f'3r4>'5rV\ 7r-A'>x77'o^^9i^ 
fOimtCffiffl^ilf^^f*^* •jTi^'EPROMiOj; 3^ 
t'a"^ xt-*^i«\ ■?-t7)K1irt§^S7'nir7 S 

m<ithtz)ht,z. ^timM'r-y vi)'^mm^ti. 

I., ii^. ::iit{SEPROMcoiei§l*l§Sr?gi-ri.Jt 

i6c7)simBSit*^'^*ni>. mn^mx'hhi)K 

^t:rz^=t')rJ<^xmm^tih^^. ^(Ty^mtz 
^^<0ilV^7 r-A'>x77-n/9A2:fil^t^Sr 
^^v^V'/i^'JiLmz^si,. EEPR0M*iK7-^>'N'7 
r-A'^X7mh7{C<5gfflSill.ii^-r-t. EPRO 
Mfc|iI«co#aT']lX0Sii5iil.'i:^A%l.. .Ititi, ts! 
*<DCD-R0MH7-f7'$iJji|nx>y:?*5, jj-^^-t-f b 



wSTD/^ 5 yi^mff)wm^^\^x\^hfz>f)X'hh. 

[00 09] «^CD-'R0MH7^/{C*tt&7r 

-i.i7x7^±iE L7t 7 7 Ti/l^- K/i^a^^asi , 

7 T-A'^X7^ ^ IJ f AM Xtjg£t'# IXo^z^ Y 

y^y<r>'>—xi)^-mmx'hhLtim^t^. 

^IXh-mti^hh. HtC. EPROMZil>'/X(iEEP 

romt'aV xm^brufy s y/{4a?gilfflcog 

1, ^j;ttfSi?hiiM*^ijit/7'n/7 s y^m& 

^tth. ^ilSc. CD-ROM H^^/CMtSAS 
fl<)^7r-A'>X77>yT^^U-Hi)m4, -«tWl2:3 

CD-ROMK7-f7'?rK03'hS-(t, 5gtC-e<7)K7^ a' 
7 7-A'>X7&7-yriJ'>-KX'#^^7CtCjg 

[00 10] 7r-A»>X7*^'7-y7'^V-H$fLl.K 

#CD-R0MK7-^ yt)mmt<^ym.^z^^irLt 

MruVy^y'/^flht. iELi.^7r-A»>x7ra 

;/7A3- H s-^tf^ ^ y t'a'^ X . tfzm^ms^ 

*i F 7 ^ 7'wm-?IIlSS tg« Lil Sill. . 

fflc^t:. 7-/r/l/-h'$flX'CD-R0MK7^7' 

m^^cr)y[z^mfihZt^zt£t^ 'MSc7)J, 

I. SM A^'f C7) K 5 ^ 7" ^ r? y t° jt. - i^X r A 
tS'imt^hh, mht^^j:i~ol>z. CD-ROMC077 7° 
y\^-Y{,z.ZWj:-kxm»^mittfdi^\<z\i^ m 

rnhzmrnxmrmtc^mmh ^tih, •t-h'xMf^ 

*<C D - R O M K 7 7'(0«tSSr . m&m^^tlt t'O 

[00 11] iim, ^B°aiowwtisri5]i>cD- 

R OM K 7 fizMt 1. 7 r - A '^X7<7)7 y 

^. mma. 7-yryv-viMmii<zm^j:-kx 
mmmxn-wizn^^xii.-moizmsi'. mmizmt 

mmt^miz. 7^x^ayt°a-^'i/XTAA>^>H7 

^ymm-tmmi:mthmm'fh, 7 
miMixmamm^im^^iztmh. k?^ 

A'com**t:i: o-Cii. fa-:?xxr A*^^> F7 
If^^rC D-R0MF7-f y<0{iiacOL''<.;l^ t (SI t 
[00 12] 
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ayh-jL-^'v-XrAc^ATA/ 1 DE'f X- 
;^ Sr^n- LTtK^t -f ;^ ^ K 7 7't 7 t -A-^xt 3- 

[0013] *l|H3i7)ffiO@W{i, 7 r-A':7X73- 

A/I DE^y^-7x-;!.f:frtT3t^T^:^^' F7 

7 T -i^ XT 3 - K :t y^-^ h T'7 -y 7'/lx 
[00 14] 

[asi^f)i^-ri.!t46c7)^g] ±ie@w^«jiEti.!^c 

*^BjT-{4. ATA/I DE^y^-7x-X$r^l• 
L■r3t^T>f J^:^' H^'f 7fflc07r-A'^X73- h'?: 

7-^7'(i. l?ie7r-A'>xr:3-F^XbTtl)^46 
<0;'<^ yr^'-^'-^Xt, ffia7 7-A'>xTa-HS:||ff 

ttfife K ^-^ J: ^.fi^ae^T -f x;? i^§or iJ'-b 

/ 1 D E y - 7 X -X :fr LT BuiE3t^T -f :^ ^' F 
H 7>f 7'(^il?ISt!i#&iNH$tS t ^^^LTV^ 

mmAm^i. mm i i^A:^]i4miero/7 s y 

/ayhD-^^Mg^^ti. |tilBm2c^A:^{4|!ifE 
v^^'aayhn-^cg^^ii. -e LTIulE^a-ftS 
tRAi^tifilEra:?- 7 S y/^ ^-7';Wfi-t^gjlt 
S, mlEvyUf-T-V^^-y-ti. fifE*;^F3yti-^'i/ 

SC, 7r-A'>xrr-y7'/^-F»ift^fr^7t:a6 
tc. BulE^«^l:ffi:^]^:n-L-Ciiii!EllliOA:'j^HiifE^* 

[0015] *^HB(0±iefl!!C0@WS-5il!£tl./ci^, * 
^BBiMtC. ATA/I DE^y^-7x-xS::n-tT 
^' F 7 ^ /fflcO 7 7 - A "^x T 3 - F 5: 7 y 

7°^u-Fts:^ft-ej>o-c, mm^T'iT.yy^'jA 

-fM. Buie7 7-A'^X73-FSrXF7-fl>/.'*^cO>< 
tUf>^'^Xt. |f|ia7r-A'>x73-F^^ffLT 
lute F ^-^ 7'tc J: SKifE3K^f -f l*|g£^7i? -t x»i 
f^S:©Jfflltl.v^ ^' 03 y F n-7 h $-<ii.l.:5S&S 



mlEATA/l DE>fy:$'-7x-X3&^<^fi^2:g 
<St. -?-LTA:']/a}^)f3-F$:ff-^T, frifi^XF 
3 y tjL- ^'>'XTA:«)iBgie7 7 -Ai^X7<7)7 V 7°^^ 
U-F^g^LTV^|.*\ -mmW^^AX^YvA 

3 y t° a- V-;^TA3!)lf7 7 -is '>X7<7)7 7 r/P- 
FS-g^tfcfc liffEATA/I DE-f y:J'-7x 
BiiiE^ ^ y T AM X U . lii IEtJ-^ X F 3 y u 
a-^*^fifE;< ^: 'J r A'^ xizUtmr^tsZ b t J: I, 
7 7-i.'>x777 7°/lx-FmcO||fir^rF^L. ^ 
LTmE*x F syta-^J'vJ^rAiSHufBTt^T ;^ 
^' F7^ 7-c7)a^||)f^^^*Uc b # |irfB7>f iJ'o 
3 y F n- 7 ^Wi^ t U t'aM :^l,zmm-h, 
[0016] 

mi^zx-^xm^Mz^iii, ;i<ommmHLt:mmt: 
mixmixi. 

[00171 iSft<0A--V-f;!^3ytra-^'{I*rt. C 
D-ROM F*9>f y{43i^£|«ffl$ilTt^S3fe^T 

F7>f7'(^A^^AJ6TV^^*\ .rcOBJ3fflST'ffiffl1-|. 
'■^^7-'-fX^'F7^r' fcV^afflim. |5ltCD77 
S U -SriSjii: tTJfi < \mt^ DVDYy^yff)Xd 

[00 18] — *;^F3ytjL-^'i^xrA<?)jifi 
■fhfzMzm^a^C'D-ROM. F 7>f 7'tdiicaat7)^ 
y^''-7x-;^^>{)<affl$*i-Cv^S*i, ^.tzhiicrni 

ATA/ 1 DE (Intelligent Disk Electronics ±tz 
{4 Industrial Disk Electronics ) -?-<7)5|-ft; 
A'-i/gyE I DEt'J)!.. fficOS*W4. SCS I 
(Small Cojputer System Interface ) i:^^°7^'/^^— 

v-^y-^-yx.-xifi^ttih, immzi.t^r^ 

X^YyA:fcr>tzisb<^7r~l.'l:si7-:i-Yi7yry 
V-Ythmii. Lt-^Lti:ii^^. ATA/lDE>fy 
9-7 x-::k^^mthzri^(r)Yy-^7'^ff}M^^zWk 

[0019] ^w^t:mm-h m<7)rzisbi<z. imcri i 
DE CD-ROM F 7^ 7rm<^nmmmmM.ifi\:x 
Tx-m.^iih.mi^zm'koi.z. ata/ide^ 

y^-7x-X$-#9^<^CD-R0M{4. IDE-'N' 
xiO^itLXt^XYzxy'^a.-^'yX^Jxtmmth 

[ 0 0 2 0 1 -^^r C D - R O IW F 7 ^ rffl<7)Si|ffll|aI 

182 0(4. vyMfffymmmmth-^^ifu-^y 
Fn-7 (/iC) 23mth. zmwm2o\i^ 

ic, f^^s-o-Yb F7-^7'7 7-A'>X77-n/7A(:0 
T-^i:^*SllWS;ti6co^if^tt^^'J (NVM) 2 
3S:fiiil.. ^L^J:3t, ||SW=2:CD-R0]VIF 
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si^thfzl^^CY)-ROV[f':i-y (CD-ROM 
DEC) 2 1^1®^.^. ||MW^$lplHlif§2 0{i« mi 

(i\ CD-ROM K7^:^i)f^tL-rfi^^Majt^^ 

;^yty (DRAM) 25\,zx^xm<^ixhmm^ 

[0021] i^#^Ii:->t^i^<a^>i^-Cv^|,«(c, 

-■mmm (mech servo t. r^^^x 

Lf^C Dr-^'fflc7)T'x:5';^v:5'•'-^;^T□-fe-y1^ ( D s 

p) i:. fi>^)v=^'m7i-um^^zmm-ttz)^(r> 

T'y^)V-7-tufm^ {^J^O CD-ROM 

t\ 0J8PliK2 0 nxnmz^^y 9X29t iXTT^^fl 

[00 2 2] [12{i, AiaW^I DE CD-ROM)-' 
y4-f<D-mtLX, v^^'n3yhD-723, CD 
-R0M7'3-:J^2 1 . ^»llft^tU 2 4ffli:iaort 

lo\Z. CD-ROM K5^7'(7)V>f:7aayhu-7 
2 3{4. F7'f7"i->yM^(?)l^C0T-^'7^'-fe;^iJ 

;iiX\i. CD-ROM K7-<7'y7h'>X7Srll4Tt. 
fLT I DE-^ >':J'-7x-;?.>Ul 0<50SJPI DEft 
■f-<7)-fe -y h 5r :f> L T)^ 7 •< 7-7 :7 p 3 y h n- 7 2 3 

A';^ ^ y ^' - 7 X -;^fi^O-b y h tz{4 , s'-f x T K 
UXfi^HA0-2t, A^/tll^^-MiRfi^Hc 
SO- It. 16f7h<7)f-:?^'«;^HD0-l St. 
ffiO«!HiMi-ti: UT 'J- K/5>f h;^ h o-rff-^H R 
D/HWRt , fjaSiR/iliSrt-f H I RQ/HD RA 
Q/HDACKt. 'J-fe-y h<if-RESETt. 16t' 
•y h I /OISj^Xr-:?Xj§S^^ I 0 C S 1 6 1 

[0 0 2 33 *|&BH{cf^|, ATA/ ID E>fy^-7x 
-X^-f^LXit^f >i X9 l-'7^7'c^7r-A'>xr3 
~¥i7-/7'^l'-Y'thfz»)C:i^Wii. CD-ROM 

hcoX'hh, 

[ 0 0 2 4 ] *||BBtw«l> ATA/ 1 D E-f y;? 7 X- 



HS:7'yr^l^-Ktl.?tV)C7)^S«^S*«fcl;{4, AT 
A/I DE'fy^'7x-X^:^LT*Xb3>'fa-:5' 

$<t3t3S^{4, *Xhr7>'lfj.-:J'v-;^TAj5»\ CD- 
ROM K ^ rcoa^cof -^^ 7 9 -b ;?.i))fpc7)||H#S:g 

tizX-oX-^yt^ ht-7T-A'>x73-H2r7-yr 

b3yta-^'vXTA*S:t>'-9-'f hC07r-A'>X7 

<7)7'y7°/U— K5r^^tl>^^{4, CD-ROMH7 
T'iO A T A/ 1 D E >f y iJ' 7 X -X {4^ 'J X 

*x 1- a y fa-^*^C D - RO M K 7 •< 7"ax >y hco 

l0 0 25]mL\^mmmXii. ATA/IDE-fy 

7 X - X I: :n- C D - R O M K 7 7'ffl 7 T - A 
x7CD7-y7^^U— HSrff3/c«^t, v-^^'o^yf-D 
-9 1 •eo7 r-A'>x7<?)*&hfiffl^ t y t^nV 

mmtima=j'y9 rmm) mxixmmt 

v;l.f-7V^'-t«4H7-^7"<?37r-A^x7;<^'J 

TA'/f;z.{:i6)*>a 2^mw£'f-9r9^xim'r)\ 

;?.^h'7-^7cofi^i;<^^frTTiSS$it. ^^tiiv 
/U^Tb- :7 ^: D T A'^ 7> $r :7 Q 3 y h a- 7 
fc««8L. -7^^n3yho-7*5||firtl./ii6tc^t 
|Ji6^4>7 T-A'>x7rn/7Ac7)3- K i: T-^'S:^ 

L ^ :? o 3 y f J. - i o T Hfif $ it I) * U 7 

h o- 7{4^ t U t^nV XH*f LSStfi L7i? -bx^'ttlr 

[0 0 26] 7r-A'>x73-Hl^^t'J(3*^Lg 

- K7 7 7/1^- Yifi^^Wz h % \.Zit^X h 3 y 
-^vX^h.l?to'mn'9^x^h.hi.')\z-thfz>h<ri 

^y^-7x-X(:gggL, *;<hv^XrAc7)7-0-fe-y 
t *^'7 7-A'>x7^^ y 'J^ltitif 7^'-t;?. 
T'^I.J:3lc^r^, Lm.^7'?^x\,z\t. )^^^)r)^ 
AXf\ffmk7i-)L. :<^')ir)^^Xit-h<m&\.tUh 
t. y(=tVT^U Xi}^(:><r>mtiil^Mi. iLU^V'ui^ 

[0 0271 ii-Cili'<.^)tLS^y9->f h<^7-y7-i/^ 
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[00 28] AKLT, ia3{C^§il'I.J;9(C, ATA 
/I DE-^ y:5'7x-XSr:f^tt3t^T>;^^ / 

l|B3fiOg®±, h'7>f rf|j*Pt^llIS83 OP^m-^ ^'o 
3 y h D-7 3 3 i; 7 r -A -^xr n- Kp< 'J 3 4 1 
oraiwES$it!t-7/L'f-T^^'1?- (MUX) 36^fii;t 

Ymiizmix. ^ti;TAMx3 4$:a^(o»f^t- 

Kffl^c■7'f :?u3yhn-7 3 3Wf^-ri)A\ h^^^ 
(i7T-JU';?X7c7)7>yT/L'- Hil#^- 
hra-fe 1 D E^<x 1 0 tg^t 
•?;l/f-7'l'i?-i?-3 6l:Stl?$-tt^/vrm7-n/ 
75y/3>-fo-7 (PRG CNTL) 3 2*^'fiEffl 
§iil>. Zcr,Zb^m0.thfziibl,z. ll3(cS^:?iit(r-> 
S-7;WIxi?-t3 6(4. 'e<0BS8^f^a;1-|.<};d{c. 
«2fsWt 2*f 1 co^a^krAM , 
[00 29] ^tltt. 7-p^^7 5y^^:3yha-5 3 2 
H 5 ^ 7'C07 7 -A^JiTf^U ;?.34i:V-f^o=? 

y h p-7 3 3 t . mmm^mmxmi^ 

^ na y h n-5 3 3 (4^* D 3 4 7 r -A'^xr 

tt\ 7*0/5 s y /3 y h D-7 3 2 t U fV W 
^ P7 >f 7'V-f :?03yhn-733 l,Ztmth<7)T. 
^'f ^' a a y h 3 3 {4^ cOHRa - H ^ >; T 

AM 3 3*>ii>isiJR-ri.aai L$ffl7^'^:;!.$:ll^ff 
[00 3 0] ro/7 5y/3ybD-7 3 2*< 

^ * 'J f V N'^f ;^ 3 4 S:*^T ^X^Yy^ 7'ax .y h 

I DEv-xXl Otig^^t'&t , ;h;^h3yt"a-:?>->^ 
T AC07°n-b: -y -9-{4;< ^: 'J T AM X 3 4 A.<:7)7 ^' -t X I: 
»Tt^ii:*'lt§$/l-i.. ;^t'JfAMX3 4{2*rt 
Sg!aJL*jJ:t;f»ji*<0S7^'-b;^{4. ^^UtaM:^ 

Kfctt L/mv^mm^''} -xi,zmh ^ y^f 

h(7)7r-A':7X73-K(7)77r/L'-Kc?MM$: 
it^^iil., c:ii{4. I BM5:^ayfjL-:^'v'XrA 
tSttSvArAB I OS (Basic Input /O utput Sy 
stem) a-HSr^y--l<-b' (on -board ) T-7 y7'/U- 
- H 1 1. ^ t (CSM L m^X'h h . ^ y--K- 7 -y 
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l.TitJe of Invention 

METHOD AND APPARATUS FOR UPGRADING FIRMWARE CODE FOR 
OPTICAL DISK DRIVE VIA ATA/IDE INTERFACE 

2 , C I a i in s 

1. An apparatus for upgrading die firmware code of an oplical disk 
dri ve via the ATA/IDE interface, the optical disk drive comprises a memory device 
for storing the firmware code, a microcontroller executing the firmware code for 
controlling the optical disk content access operation of the drive, and a drive 
decoder for decoding to connect the optical disk drive to a host computer system 
via the ATA/IDE interface, the apparatus comprising: 

a programming controller means, receiving signals from the ATATIDE 
i Dierface and performing input/output decode for generating a programming enable 
signal that determines whether the host computer system has requested for upgrade 
of the firmware or for maintaining the optical disk drive in normal operation; and 

a multiplexer means, having a first and a second input, a multiplexed 
output and a multiplexing select input, the first input being connected to the 
programming controller means, the second input being connected to the 
microcontroller, and the multiplexing select input receiving the programming 
enable signal, the multiplexer means switching the first input to the memory device 
via the multiplexed output for performing a firmware upgrade operation when the 
host computer system requests for a firmware upgrade. 

2. The apparatus for upgrading the firmware code of an optical disk 
drive via the ATA/IDE interface of claim 1, wherein the programming controller 
means fiirther comprising: 

an input/output decoder, receiving signals firom the ATA/IDE intcrfecc 
and performing the input/output decode for generating the programming enable 
signal and fiirther generating a first, a second, a third and a fourth enable signal; 

an initialization key enable logic, receiving the first enable signal and 
the corresponding signals fix)m the ATA/IDE interface for generating an upgrade 
initialization key signal when the host computer system requests for a firmware 



(17) 



1*^^11-120 113 



upgrade; . 

an address program enable latch, receiving the upgrade initialization 
key signal, the second enable signal, and the corresponding signals from the 
ATA/IDE interface for latching the corresponding signals on the ATA/IDE 
interface to generate the writtra address signals for the memory device v/hcn the 
host computer system requests for a firmware upgrade; 

a data program enable latch, receiving the upgrade initialization key 
signal, the third enable signal, and the corresponding signals from the ATA/IDE 
interface for latching the corresponding signals on the ATA/IDE interface to 
generate the written data signals for the memory device when the host computer 
system requests for a fimiware upgrade; and 

a control program enable latch, receiving the upgrade initialization key 
signal, the fourth enable signal, and the corresponding signals from the ATA/IDE 
interface for latching the corresponding signals on the ATA/IDE interface to 
generate the writing control signals for the memory device when the host computer 
system requests for a firmware upgrade. 

3. The apparams for upgrading the firmware code of an optical disk 
drive via the ATA/IDE interface of claim 2, wherein the corresponding signals 
received by the address program enable latch from the ATA/IDE mterface when 
the host computer system requests for a firmware upgrade comprises the total 16- 
bit address signals of the ATA/IDE interface. 

4. The apparatus for upgrading the firmware code of an optical disk 
drive via the ATA/IDE interface of claim 2. wherein the corresponding signals 
received by the data program enable latch from the ATA/IDE interface when the 
host computer system requests for a firmware upgrade comprises at least the least 
significant eight bits of the data signals of the ATA/IDE interface. 
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5. The apparatus for upgrading the fimwarc code of an optical disk 
drive via the ATA/IDE interface of claim 2, wherein the corresponding signals 
received by the control program enable latch from the ATA/IDE intcrfece when the 
host computer system requests for a firmware upgrade comprises at least the least 
significant eight bits of the data signals of the ATA/IDE interface. 

6. The apparatus for upgrading the firmware code of an optical disk 
drive via the ATATIDE interface of claim 2, wherein the optical disk drive is a 
CD-ROM drive. 

7. The apparatus for upgrading the firmware code of an optical disk 
drive via the ATA/IDE interface of claim 2, wherein the optical disk drive is a 
DVD drive. 

8. An apparatus for upgrading the firmware code of an optical disk 
drive via the ATA/IDE interface, the optical disk drive comprises a memory device 
for storing the firmware code, a microcontroller executing the firmware code for 
controlling the optical disk content access operation of the drive, and a drive 
decoder for decoding to connect the optical disk drive to a host computer system 
via the ATA/IDE interface, the apparatus comprising: 

a programming controller means, receiving signals from the ATA/IDE 
interface and performing input/output decode for generating a programming enable 
signal that determines whether the host'computer system has requested for upgrade 
of the firmware or for maintaining the optical disk drive in normal operation, the 
programming controller means comprises: 

an input/output decoder, receiving signals from the 
ATA/IDE interface and performing the input/output decode for 
generating the programming enable signal and further generating a 
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first, a second, a third and a fourth enable signal; 

an initialization key enable logic, receiving ihc first enable 
signal and the conresponding signals from the ATA/IDE interface for 
generating an upgrade initialization key signal when the host computer 
system requests for a firmware upgrade; 

an address program enable latch, receiving the upgrade 
initialization key signal, the second enable signal, and the 
corresponding signals from the ATA/IDE interface for latching the 
corresponding signals on the ATA/IDE interface to generate the written 
address signals for the memory device when the host computer system 
requests for a firmware upgrade; 

a data program enable latch, receiving the upgrade 
initialization key signal, the third enable signal, and the corresponding 
signals from the ATA/IDE interface for latching the corresponding 
signals on the ATA/IDE interface to generate the written data signals 
for die memory device when the host computer system requests for a 
firmware upgrade; and 

a control program enable latch, receiving the upgrade 
initialization key signal, the fourth enable signal, and the corresponding 
signals from the ATA/IDE interface for latching the corresponding 
signals on the ATA/IDE interface to generate the writing control 
signals for the memory device when the host computer system requests 
for a firmware upgrade; and 

a multiplexer means, having a first and a second input, a multiplexed 
output and a multiplexing select input, the firet input being connected to the 
programming controller means, the second input being connected to the 
microcontroller, and the multiplexing select input receiving the programming 
enable signal, the multiplexer means switching the first input to the memory device 
via the multiplexed output for performing a fmnwarc upgrade operation when the 
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9. The apparatus for upgrading the firmware code of an optical disk 
drive via the ATA/IDE interface of claim 8, whcnsin the corresponding signals 
received by the address program enable latch from the ATA/IDE interface when 
the host computer system requests for a firmware upgrade comprises the total 16- 
bit address signals of the ATA/IDE interface, 

10. The apparanis for upgrading the fimiware code of an optical disk 
drive via the ATAVIDE interlace of claim 8, wherein the corresponding signals 
received by the data program enable latch from the ATA/IDE interface when the 
host computer system requests for a firmware upgrade comprises at least the least 
significant eight bits of the data signals of the ATA/IDE interface. 

1 1. The apparatus for upgrading the firmware code of an optical disk 
drive via the ATAyiDE interface of claim 8, wherein the corresponding signals 
received by the control program enable latch from the ATA/IDE interface when the 
host computer system requests for a firmware upgrade comprises at least the least 
significant eight bits of the data signals of the ATA/IDE interface. 

12» The apparatus for upgrading the firmware code of an optical disk 
drive via the ATA/IDE interface of claim 8, wherein the optical disk drive is a 
CD-ROM drive. 

13. The apparatus for upgrading the fmnware code of an optica] disk 
drive via the ATA/IDE interface of claim 8, wherein the optical disk drive is a 
DVD drive. 



(21) 



im^f-l 1-120 113 



1 4. A method for upgrading the firmware code of an optical disk drive 
via the ATA/IDE interface, the optical disk drive comprises a memory device for 
storing the firmware code and a microcontroller executing the firmware code for 
controlling the optical disk content access operation of tfie drive; the method 
comprising the steps of: 

the optical disk drive receiving signals firom the ATA/IDE interface 
and performing input/output decode determines whether the host computer system 
has requested for upgrade of the firmware or for maintaining the optical disk drive 
in normal operation; and 

the optical disk drive connecting the ATA/IDE interface to the memory 
device, allowing for a host computer to perform a firmware upgrade operation by 
directly writing into the memory device when the host computer system requests 
for a firniware upgrade, and connecting the microcontroller to the memory device 
when the host computer system requests for the normal operation of the optical 
disk drive. 

15. The method for upgrading the fimiware code of an optical disk 
drive via the ATA/IDE interface of claim 14, wherein the optical disk drive is a 
CD-ROM drive. 

16. The method for upgrading the firmware code of an optical disk 
drive via the ATA/IDE interface of claim 14, wherein tiie optical disk drive is a 
DVD drive. 

1 7. A method for upgrading the firmware code of an optical disk drive 
via the ATA/IDE interface, the optical disk drive comprises a memory device for 
storing the firmware code, a microcontroller executing the firmware code for 
controlling the optical disk content access operation of the drive, a drive decoder 
for decoding to connect the optical disk drive to a host computer system via fiie 
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ATA/IDE interface, a multiplexer means and a programming controller means, the 
multiplexer means having a first and a second input, a multiplexed output and a 
multiplexing select input, the first input being connected to the programming 
controller means and the second input being connected to the microcontroller, and 
the programming controller means selectively switching the multiplexing of the 
multiplexer means; the method comprising the steps of: 

the programming controller means receiving signals from the 
ATA/IDE interface and performing input/output decode for generating a 
programming enable signal that determines whether the host computer system has 
requested for upgrade of the firmware or for mainuining the optical disk drive in 
normal operation; and 

the multiplexer means having the multiplexing select input receiving 
the programming enable signal for switching the first input to the memory device 
via the multiplexed output for performing a firmware upgrade operation when the 
host computer system requests for a firmware upgrade. 

18. The method for upgrading the firmware code of an optical disk 
drive via the ATA/IDE interface of claim 17, wherein the step of the piogramming 
controller means generating the programming enable signal fiiither comprising the 
steps of: 

an input/output decoder of the programming controller means 
receiving signals from the ATA/IDE interface and performing the input/output 
decode for generating the programming enable signal and further generating a first, 
a second, a third and a fourth enable signal; 

an initialization key enable logic of the programming controller means 
receiving the first enable signal and the corresponding signals fi^m the ATA/IDE 
interface for generating an upgrade initialization key signal when the host 
computer system requests for a firmware upgrade; 
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an address program enable latch of (he programming controller means 
receiving the upgrade initialization key signal, the second enable signal, and the 
corresponding signals from the ATA/IDE interface for latching the corresponding 
signals on the ATA/IDE interface to generate the written address signals for the 
memory device when the host computer system requests for a firmware upgrade; 

a data program enable latch of the programming controller means 
receiving the upgrade initialization key signal, the third enable signal, and the 
corresponding signals from the ATA/IDE interface for latching the corresponding 
signals on the ATA/IDE interface to generate the written data signals for the 
memory device when the host computer system requests for a firmware upgrade; 
and 

a control program enable latch of the programming controller means 
receiving the upgrade initialization key signal, the fourth enable signal, and the 
corresponding signals from the ATA/IDE interface for latching the corresponding 
signals on the ATA/IDE interface to generate the writing control signals for the 
memory device when the host computer system requests for a firmware upgrade. 

19. The method for upgrading the fimfiwaie code of an optical disk 
drive via the ATA/IDE interface of claim 18, wherein the corresponding signals 
received by the address program enable latch from the ATA/IDE inter&ce when 
the host computer system requests for a firmware upgrade c(Hnprises the total 16- 
bit «ldress signals of the ATA/IDE interface. 

20. The apparatus for upgrading the firmware code of an optical disk 
drive via the ATA/IDE interface of claim 18» wherein the conesponding signals 
received by the data program enable latch firom the ATA/IDE intcrfecc when the 
host computer system requests for a firmware upgrade comprises at least the least 
significant eight bits of the data signals of the ATA/IDE interface. 
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21. The apparatus for upgrading the finnwarc code of an optical disk 
drive via the ATA/IDE interface of claim 18, wherein the conesponding signals 
received by the control program enable latch fixwn the ATA/IDE interface when the 
host computer system requests for a firmware upgrade comprises at least the least 
significant eight bits of the data signals of the ATA>1DE interface. 

22. The apparatus for upgrading the firmware code of an optical disk 
drive via the ATA/IDE interface of claim 18, wherein the optical disk drive is a 
CD-ROM drive. 

23. The apparatus for upgrading the firmware code of an optical disk 
drive via the ATA/IDE interface of claim 18, wherein the optical disk drive is a 
DVD drive. 

24. A method for upgrading the firmware code of an optical disk drive 
via the ATA/IDE interface, the optical disk drive comprises a memory device for 
storing the firmware code, a microcontroller executing the fimiware code for 
controlling the optical disk content access operation of tfie drive, a drive decoder 
for decoding to connect the optical disk drive to a host computer system via the 
ATA/IDE interface^ a multiplexer means and a programming controller means, the 
multiplexer means having a first and a second input, a multiplexed output and a 
multiplexing select input, the first input being connected to the programming 
controller means and the second input bemg connected to the microcontroller, and 
the programming controller means selectively switching the multiplexing of the 
multiplexer means; the method comprising the steps ofc 

the programming controller means receiving signals from the 
ATA/IDE interface and performing input/output decode for generating a 
programming enable signal that determines whether the host computer system has 
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requested for upgrade of the firmware or for maintaining the optical disk drive in 
normal operation, the generation of the programming enable signal further 
comprising the steps of: 

an input/outpui decoder of the programming controller 
means receiving signals from the ATA/IDE interface and performing 
the input/output decode for generating the programming enable signal 
and fiirther generating a first, a second, a third and a fourth enable 
signal; 

an initialization key enable logic of the programming 
controller means receiving the first enable signal and the corresponding 
signals from the ATA/IDE interface for generatmg an upgrade 
initialization key signal when the host computer system requests for a 
firmware upgrade; 

an address program enable latch of the programming 
controller means receiving the upgrade initialization key signal, the 
second enable signal, and the corresponding signals from the ATA/IDE 
interface for latching the corresponding signals on the ATA/IDE 
interface to generate the written address signals for the memory device 
when the host computer system requests for a firmware upgrade; 

a data program enable latch of the programming controller 
means receiving the upgrade initialization key signal, the third enable 
signal, and the corresponding signals from the ATA/IDE interface for 
latching the corresponding signals on the ATA/IDE interface to 
generate the written data signals for the memory device when the host 
computer system requests for a firmware upgrade; and 

a control program enable latch of the programming 
controller means receiving the upgrade initialization key signal, the 
fourth enable signal, and the corresponding signals from the ATA/IDE 
interface for latching the corresponding signals on the ATA/IDE 
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interface to generate the writing control signals for the memory device 
when the host computer system requests for a firmware upgrade; and 
the multiplexer means having the multiplcTung select input receiving 
the programming enable signal for switching the first input to the memory device 
via the multiplexed output for performing a firmware upgrade operation when the 
host computer system requests for a fiirnware upgrade. 

25. The method for upgrading the firmware code of an optical disk 
drive via the ATA/IDE interface of claim 24, whereirj the corresponding signals 
received by the address program enable latch from the ATA/IDE interface when 
the host computer system requests for a firmware upgrade comprises the total 16- 
bit address signals of the ATA/IDE interfece. 

26. The apparanis for upgrading the firmware code of an optical disk 
drive via the ATA/IDE interface of claim 24, wherein the corresponding signals 
received by the data program enable latch fiom the ATA/IDE interface when the 
host computer system requests for a firmware upgrade comprises at least the least 
significant eight bits of the data signals of the ATA>IDE interface. 

27. The apparatus for upgrading the firmware code of an optical disk 
drive via the ATA/IDE interface of claim 24, wherein the corresponding signals 
received by the control program enable latch fiiom the ATA/IDE interfece when the 
host computer system requests for a firmware upgrade comprises at least the least 
significant eight bits of the data signals of the ATA/IDE interface. 

28. The apparatus for upgrading the firmware code of an optical disk 
drive via the ATA/IDE interface of claim 24, wherein the optical disk drive is a 
CD-ROM drive. 

29. The apparatus for upgrading the firmware code of an optical disk 
drive via the ATA/IDE interface of claim 24, wherein the optical disk drive is a 
DVD drive. 
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BACKGROUND OF THE INVENTION 
Field of the Invention 

The invention relates in general to on-site upgrading of firmware code 
in optical disk drives. In particular, the invention relates to an apparatus for optical 
disk drives and its corresponding method capable of implementing firmware code 
upgrade via the ATA/IDE interfece of the host computer system. 
Technical Background 

Optical disk drives, in particular the category of CD-ROM drives, have 
become the digital optoelectronic memory storage equipment so popular that 
almost every personal computer system has at least one installed, in the world of 
personal computers, the design of CD-ROM drives was intended originally for the 
storage of mass information on the CD-ROM discs. The concept, in a sense, is 
basically the same as the magnetic disk drives, which store information on the 
surface of the storage media. No writing capability is available to the user for this 
member of the CD family, and thus the name "CD-ROM." Large data is, however, 
accessible finom CD-ROM discs that are mass produced in low cost. 

Although CD-ROM has been adopted by the ISO as a standard for 
digital data storage, there are also other applications beyond the simple storage of 
large amount of data. Under proper software control, a CD-ROM drive may also 
be used to access several other types of discs in the CD family. 

For example, in personal computer systems, CD-ROM drives are 
frequently used as the traditional CD player for playing back music pieces stored 
on the very first generation of CD, namely, the music CD. After the introduction of 
the original music CD, there had emerged in the family such formats as the Video 
CD (VCD). Conventional CD-ROM drives for personal computer systems arc 
designed to be able to play back VCD video programs on the computer display 
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screen. Due to the inherent limitation of the MPEG-1 adopted, the VCD standard 
is not for serious applications, and a couple of groups of electronic appliance 
conglomerates had recently achieved on a new standard known as the Digital 
Video Disc (or Digital Versatile Disc). 

This is a new video data storage format, a new member of the CD 
family based on the MPEG-2 standard that provides substantially better video 
effects via the use of higher resolution. As the DVD standard had proposed, 
backward compatibility for the new generation of DVD drives to the CD-ROM 
format has been designed into the new system. In other words, the up-coming 
DVD drives will be able to read CD-ROM in addition to its default DVD. 

Thus, as an optical Compact Disc subsystem for a computer system, 
the CD-ROM drive can be programmed to access different formats of the CD 
family of media. In the popular x86-bascd IBM-compatible machines, this is 
implemented in a manner known as software driver installation. With the 
installation of the proper software drivers, the computer system, governed by the 
operating system, can be used to read data files stored on the CD-ROM, playback 
music CD, or video VCD. These software drivers are essentially established on top 
of the hardware-level control program resident in the control system of a CD-ROM 
drive. This firmware program is usually stored in non-volatile semiconductor 
memory devices, such as the erasable-programmable read-only memory (EPROM) 
or electrically erasable-programmable read-only memory (EEPROM), 

Based on this firmware, CD-ROM drives can be controlled by the host 
computer system to suitably implement the fiinctionahty of music CD player, VCD 
player, and/or CD-ROM data drive. However, under certain circumstances, in 
particular when new models of CD-ROM drives are released to market for sale, 
software programs, either the firmware in the control electronics of the drive itself 
or the operating system/apphcation- level driver, may have program problems 
(program bugs) that might cause the drive to malfunction. If the problem was with 
the operating systcm/application-levcl driver, it's fix may not involve the CD- 
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ROM drive at all. If, however, the problem was unfortunately with the firmware of 
the CD-ROM drive, the software fix will inevitably cause many trouble. 

BasicaMy, if the drive firmware has any program problem, the firmware 
stored in the semiconductor memory device must be upgraded, namely, replaced 
by another copy without problem. If the semiconductor memory used for holding 
the firmware program was device like EPROM, il must be removed from its 
inserted socket or de-soldered from the printed circuit board so as to implement 
reprogramming of its memory content. Normally, this involves ultraviolet 
irradiation on the EPROM device for its memory content erasure. If the erased 
memory device was to be reused again, as is usually the case, it then has to be 
reprogrammed to hold the new problem-free firmware program. Even if an 
EEPROM device was used to store the drive firmware, it must be handled in the 
manner as in the case of EPROM. This is because the conventional CD-ROM 
drive control logic lacks the design for on-site reprogramming. 

The above-described procedure of firmware upgrade/fix for the 
conventional CD-ROM drives requires that the casing of the drive be opened in 
order to be able to have access to the firmware memory device. Before the memory 
device can even be accessed, the CD-ROM drive itself must be removed from the 
drive bay of the computer system unit, if it has already been installed. Further, 
erasure and programming of EPROM and/or EEPROM devices normally require 
the use of dedicated equipment such as ultraviolet eraser and programmer. 
Therefore, typical fimiware upgrade operation for a CD-ROM drive is not 
normally handled by the end user of the computer system. A more likely scenario 
would be to have service personnel remove the CD-ROM drive from the system, 
and have the drive sent back to the manufacturer's site where ihc firmware gels 
upgraded. 

When the CD-ROM drive whose fumwarc is to be upgraded is 
returned to the manufacturer's facility, the casing is opened, and the memory 
device is removed from the drive electronics utilizing proper tools and/or 
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equipment. After reprogramming, the memory device* or a substitute thereof 
containing the correct firmware program code, may then be replaced back into the 
drive electronics. After adequate testing procedures, the upgraded CD-ROM drive 
is ready to be returned to the owner. Again, qualified personnel must replace the 
drive back into the computer system. As is obvious, relatively complicated 
professional knowledge is required to perform all the tasks involved in the upgrade 
of a CD-ROM drive. In a time when severe competition has driven the prices of 
CD-ROM drives down to the level where it is difficult for manufacturers to 
maintain a descent profit margin, such upgrading operation is strictly disastrous. 

This is because the necessity to perform finnwaie upgrade for a CD- 
ROM drive often arises within the warrantee period of the product As such, it is 
convention that the manufacturer will have to be responsible for the expenditures 
of drive removal from the host computer system as well as shipment, not to 
mention all the additional man power required to perform the upgrade. On the 
other hand, in the process of upgrade, the drive and its components may easily be 
subject to damages to cause additional loss. For the drive owner, the cost to find 
some technician to remove the drive fi*om the computer system (if the 
manufacturer was not going to be responsible) may frequently amount to the level 
of the cost of some low-end CD-ROM drives. 

SUMMARY OF THE INVENTION 

It is therefore and object of the invention to provide an apparatus and 
its cwTCsponding mediod for upgrading firmware code on-site foi" optical disk 
drives via the ATA/IDE interface of the host computer system without having to 
remove the drive unit from the computer and opening up the cabinet 

It is another object of the invention to provide an apparatus and its 
corresponding method for upgrading firmware code on-site for optical disk drives 
via the ATA/IDE interface of the host computer system by the host processor 
direcdy writing into the memory device holding the firmware code. 
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[n order to achieve the above objects, the invention provides an 
apparatus for upgrading the firmware code of an optical disk drive via the 
ATATIDE interface, the optical disk drive has a memory device for storing the 
firmware code, a microcoDtroller executing the firmware code for controUing the 
optical disk content access operation of the drive, and a drive decoder for decoding 
to connect the optical disk drive to a host computer system via the ATA/IDE 
interface. The apparatus includes a programming controller that receives signals 
from the ATA/IDE interface and performs input/output decode for generating a 
programming enable signal that determines whether the host computer system has 
requested for upgrade of the firmware or for maintaining the optical disk drive in 
normal operation. A multiplexer has a first and a second input, a multiplexed 
output and a multiplexing select input, the first input is connected to the 
programming controller, the second input connected to the microcontroller, and the 
multiplexing select input receives the programming enable signal. The multiplexer 
switches the first input to the memory device via the multiplexed output for 
performing a firmware upgrade operation when the host computer system requests 
for a firmware upgrade. 

To achieve the above objects, the invention further provides a method 
for upgrading the firmware code of an optical disk drive via the ATA/IDE 
interface, the optical disk drive has a memory device for storing the firmware code 
and a microcontroller executing the fimware code for controlling the optical disk 
content access operation of the drive. The method includes the steps of first having 
the optical disk drive receive signals from the ATA/IDE interface and pcrfom™ 
input/output decode to determine whether the host computer system has requested 
for upgrade of the firmware or for maintaining the optical disk drive in normal 
operation. Then the optica! disk drive connects the ATA/IDE interface to the 
memory device, allowing for a host computer to perform a firmware upgrade 
operation by directly writing into the memory device when the host computer 
system requests for a firmware upgrade, and connects the microcontroller to the 
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memory, device when the host computer system requests for the normal operation 
of the optica] disk drive. 

DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENTS 

Note that although for present-day personal computers, CD-ROM 
drives constitute the majority of optical disk drives currently in service, however, 
the term "optical disk drive" referred to in this specification should include other 
types of optical disk drives such as the emerging DVD drive which also originates 
from the same CD family. 

On the other hand, although there are several interface standards 
currently adopted by conventional CD-ROM drives for communicating with their 
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host personal computer systems, however, the majority being the ATA/IDE 
(Intelligent Disk Electronics or Industrial Disk Electronics) standard, or its 
enhanced version EIDE. Other standards include (he SCSI (Small Computer 
System Interface) and even the parallel port interface. The apparatus for upgrading 
firmware code for optical disk drive of the invention, however, concentrates on the 
application to those drives with the ATA/IDE interface. 

For the purpose of describing the invention, the general control 
circuitry configuration for a conventional IDE CD-ROM drive is examined below. 
As is illustrated in FIG. 1, the conventional CD-ROM drive with ATA/IDE 
interface has the built-in control electronics generally identified by the reference 
numeral 20 communicating with the host computer system via the IDE bus 10. 

Control circuitry 20 for the typical CD-ROM drives includes a 
nucrocontroller (^C) 23, which is responsible for coordinating the internal 
operation of the drive. The circuitry 20 further includes a non-volatile memoiy 
device (NVM) 24 for the storage of the instruction code and data of the drive 
firmware progranu As is sejen in the drawing, the typical CD-ROM drive provides 
the firmware code to the microcontroller 23 only via read access, as is signified by 
the single-directional arrow in the drawing. The circuitry 20 has a CD-ROM 
decoder (CD-ROM DEC) 21, which allows for the interacting operation between 
the microcontroller 23 and the host computer system via the interface IDE bus 1 0. 
A typical drcuitry 20 fuitfaer has a working memory space, which can be provided 
by, for example, a dynamic random-access memoiy (DRAM) 25 that serves one 
impcNTtant function of read caching as the CD-ROM drive operates. 

As persons skilled in the art are well famiiiar, the control ciicuitiy 20 is 
further complete with the mechanism servo control (MECH SERVO) for (he laser 
pick-up head, the digital signal processor (DSP) for the accessed CD data, as well 
as the digital-to-analog converter (D AC) for converting die digital music data into 
analog signal and the preamplifier (PREAMP) for the amplification of this analog 
music signal when the CD-ROM is operated as a music CD player. Circuitry of 
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these functional blocks are simply represented by a box 29 in the circuitry 20 as 
they are not the subject matter of the invention and will nol be elaborated here. 

FIG. 2 shows the details of the inter-connection circuitry between the 
microcontroller 23 and the CD-ROM decoder 21, as well as the non-volatile 
memory 24 of an example of a typical IDE CD-ROM drive. As is familiar to 
persons skilled in the art, the microcontroller 23 of the CD-ROM drive may 
proceed with its normal data access operation in the drive unit under control of the 
host computer system. This is done by the host processor executing the CD-ROM 
driver software and communicating with the drive microcontroller 23 via the set of 
standard IDE signals in the IDE interface bus 10. This set of bus interface signals 
include the device addressing signals HAO-2, the input/output port selecting 
signals HCSO-l, the 16-bil data path HDO-15, as well as other controlling signals 
including the read/write strobe signal HRD/HWR, the interrupt 
request/acknowledge signal HIRQ/HDRAQ/HDACK, the reset signal RESET, and 
the 16-bit I/O transfer status indication signal IOCS 16. 

The apparatus for upgrading fiimware code of optical disk drive via the 
ATA/IDE interface of the present invention, in one preferred embodiment 
applicable to a CD-ROM drive, allows for constructing a control circuitry such as 
the one illustrated in FIG. 3. This is a control circuitry based on the conventional 
one such as that of FIG. 1 . 

The basic concept of the inventive apparatus for upgrading firmware 
code of optical disk drives via the ATATIDE interface is to decode the instraction 
issued by the host computer via the ATATIDE interface. The decoded result 
determines that either the host computer system desires to maintain the normal 
CD-ROM drive data access operation, or it demands for an or>-site upgrade of the 
drive firmware code via writing into the code-storage memory. When the host 
computer system demands an on-site firmware upgrade, the ATA/IDE interface of 
the CD-ROM drive is then connected to the memory device, so that the host 
computer may implement the writing of the new code to the memory device. 
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When, on- the other hand, the host system requires that the CD-ROM drive unit 
returns back to normal operating mode, the microcontroller of the drive unit is then 
re-connected to the memory device, restoring its normal access of program codes 
in the memory. 

In a preferred embodiment, upgrade of the fimiware for a CD-ROM 
drive via the ATA/IDE interface employs to insert a controlled signal multiplexer 
and its related control logic between the microcontroller and its firmware storage 
memory device. This multiplexer is used to provide one of two possible data 
access routes toward the firmware memory device of the drive. One of the routes is 
established under normal operating condition of the optical disk drive, in which the 
multiplexer connects the memory device to the microcontroller so that the 
microcontroller can read firmware program code and data from the memory for 
execution. Obviously, this mode of memory access operation performed by the 
microcontroller on the memory device is one-directional, namely, the 
microcontroller performs read accesses in the memory device only. 

The other route that can be established to the firmware code storage 
memory device is for the memory device itself to be directly accessible by the host 
computer system when a code upgrade is ordered. In this mode of operation, the 
multiplexer connects the memory device to the [DE interface of the optica! disk 
drive unit, so that the processor of the host system can directly access the memory 
space of the firmware memory. This direct access includes both writing into and 
reading from the memory device. The ability to read from the memory device is 
necessary as it is a means to verify whether or not the correct content of 
programming has been achieved. 

The on-site upgrading operation referred to herein is defined as the 
upgrading operation performed in the firmware code storage device of the optical 
disk drive without having to remove the memory device itself from inside the 
drive. No dedicated programming tool is needed for the upgrade operation. 
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Thus, as is illustrated in FIG. 3, Ihc apparatus of the invention for 
upgrading the firmware code of optical disk drive via the ATA/IDE interface has a 
multiplexer (MUX) 36 arranged between the microcontroller 33 and the firmware 
code memory 34 of the drive control electronic circuitry 30. In addilion to the 
decode processing performed by the CD-ROM decoder 31, a programming 
controller (PRC CNTL) 32 is used to steer the multiplexer 36 for selectively 
connecting the memory device 34 either to the microcontroller 33 for normal mode 
of operation or to the IDE bus 10 for connection with the host processor in the 
fimnwarE upgrade mode of operation. In order to achieve this, as is shown in FIG. 
3, the multiplexer 36 is basically a two-to-one multiplexing device, whose details 
will be covered below. 

Therefore, when the programming controller 32 connects the firmware 
memory device 34 and the microcontroller 33 of the drive, both will be operating in 
the manner known in the art, with the microcontroller 33 performing a normal 
operation of accessing firmware program codes jfrom the memory 34, as is in the 
case of the circuitry configuration of FIG. 1. In other words, as the progranuning 
controller 32 connects the memory device 34 to the drive microcrnitrolier 33, the 
microcontroller 33 may perform its read-only access for the retrieval of its 
execution code from the memory device 34. 

On the other hand, when the programming controller 32 connects the 
memory device 34 to the IDE bus 10 of the optical disk drive unit, the processor in 
the host computer system is then allowed to implement its access to the memory 
device 34. Both write and read accesses to the memory device 34 are allowed for 
facilitating the on-site firmware code upgrade in a series of read/write operations in 
the memory device. This is an operation similar to the on-board upgrading of the 
system BIOS (Basic Input/Output System) code for the IBM-compatible computer 
systems. In such on-board upgrading operati ons, the memory device where the 
BIOS code resides needs not be removed from the motherboard of the computer 
system, and no dedicated semiconductor memory programmer equipment is 
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required.. With the proper setting of a few switches, the code upgrade operation can 
be completed by the computer system executing a software program. 

Refer to FIG. 4. FIG. 4 is a schematic diagram that shows an 
embodiment of the controller circuitry for the CD-ROM drive device employing 
the apparatus of ihe invention for implementing on-site upgrade operation of the 
finnware code. In the circuitry of FIG. 4, control can be performed to selectively 
connect the memory device 34 either to the microcontroller 33 or to the IDE bus of 
the drive, in order to perform normal operation or upgrade operation respectively. 

From the perspective of the controller, the circuitry of the 
programming controller 32 as outlined in FIG. 4 allows to convert the instruction 
and data issued by the host computer system via the IDE interface 10 into the 
electrical signals required by the memory device 34 to implement its memory 
content programming, as the upgrade of firmware code is ordered. Meanwhile, this 
circuitry of the programming controller 32 also allows for the normal connection of 
the microcontroller 33 and the memory device 34 as the drive nonnal operation is 
required. 

In order to accomplish the conversion of the code-upgrading 
instructions and data, the programming controller 32 as outlined in the circuitry of 
FIG. 4 includes an I/O address decoder (I/O ADDR DEC) 321, an upgrade 
initialization key enable logic (INIT KEY EN) 322, an address program enable 
latch (APEN) 323, a data program enable latch (DPE^f) 324^ and a control program 
enable latch (CPEN) 325. 

When an on-site upgrade operation is requested, the host computer 
system must issue a scries of correqionding instructions and data into the IDE bus 
10 in order for Ihe programming controller 32 to be operating independently from 
the bus 10 itself These instructions and data are never present over the IDE bus 10 
when the drive is in the noimal mode of operation. Instead, they only appear as an 
on-site upgrading is ordered, and these instructions and data are used to initiate the 
programming controller 32. 
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Foi instance, in a prcfened embodiment employed in the case of an 
IBM-compatible system, the processor of the host system may write a series of 32 
consecutive and pre-defmed bytes of information at the 1/0 address I F5. As is seen 
in FIG. 4, these data bytes are received over the bus lOA via the I/O address IF5 as 
decoded by the I/O address decoder 321. The data received over I/O address IF5 
are then sent to the upgrade initialization key enable logic 322. Note that bus I OA 
is an extension of the IDE bus 10 that is internal to the controller circuitry 30. 

The upgrade initialization key enable logic 322 is triggered by the 
logically positive signal at the I/O address IF5 to receive the 32 consecutive 
information bytes. If these information bytes were compared and found to be 
compatible with a predetermined set of data, then the upgrade initialization key 
enable logic 322 generates an upgrade initialization key signal [KEYOK. This 
signal IKEYOK is then relayed to the address program enable latch 323, the data 
program enable latch 324. and the control program enable latch 325 respectively. 
These three latches arc then enabled simultaneously inside the connroller circuitry 
30. 

On the other hand, the addrcss program enable latch 323 latches the 
16-bit IDE data signals HDO-15 over die bus lOA onto the bus 3236. The 
counterpart 16-bit data signals on bus 3236 axe designated as signals lAO-15. 
Meanwhile, the data program enable latch 324 also latches the least significant byte 
(eight bits) of the same 16-bit IDE data signals HDO-15 over the bus lOA onto the 
bus 3236 as the eight-bit data signals IHDO-7. In a similar manner, the control 
program enable latch 325 latches the eight least significant bits of the double-byte 
IDE data signals HDO- 1 5 over the bus lOA onto the bus 323 6, Selected ones of the 
latched bits are used as the write enable signal I WE, the chip enable signal ICE, and 
the output enable signal lOE, as well as the IDE programming enable signal 
IDEPEN that are required to strobe the memory device 34 for the implementation 
of the programming operation. 
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For example, as the IDE programming enable signal IDEPEN obtains a 
logically positive status, the processor of the host computer system may then issue 
the instruction code and data necessary to program the memory device 34. These 
instructions and data are written into the memory device 34 over the IDE bus 1 0 at 
the designated I/O addresses. For example, in the embodiment of FIG. 4, the 
address of read/write access to the memory device 34 may be issued at the I/O 
address I FO over the IDE interface in data signals HDO- 1 5. On the other hand, I/O 
address 1F3 and data bits HDO-7 may be used to relay the program code that is to 
be vmtten into the memory device 34 at the designated address space. Further, I/O 
address 1F4 and data bits HDO-7 can be used to relay the necessary device strobe 
signals OE, CE and WE that are required by the memory device 34 when 
programmed. The programming enable signal IDEPEN, which is used to indicate 
the status of the entire CD-ROM drive concerning either the drive is in a mode of 
normal operation or of upgrade progranruning operation, can itself be relayed also 
via the I/O address 1F4 as a designated bit in the data by HDO-7, 

As persons skilled in the art should be well aware, 16-bit address is 
sufficient for addressing the firmware memory device normally found in CD-ROM 
drives. For example, in the case of an eight-bit memory device, 16-bit address 
relayed via the lAO- 1 5 signal lines are capable of addressing a memory space of 64 
K bytes. For the consideration of cost reduction, eigjit-bit memory devices are 
normally used as the firmware storage device. This is suitable since optical disk 
drives such as CD-ROM drives are relatively slow peripheral devices when 
compared to the host processor of modem high-performance personal computer 
systems. The use of eight-bit data path as relayed via the IHDO-7 signal lines 
connected to the microcontroller 33 (FIG. 3) is generally adequate design 
arrangement for the normal CD-ROM drives. Further, all three memory device 
controlling enable signals lOE. IWE and ICE as well as the programming enable 
signal IDEPEN may all be obtained via the HDO-7 data bits relayed over the IDE 
interface bus. 
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Then, with reference lo FIG. 3 again, il can be seen that the circuitry of 
Ihc programming controller 32 may transfer the 16 address signals I AO- 1 5, the 
eight data signals IHDO-7, and the four control signals ICE, lOE, IWE and 
IDEPEN onto bus 3236 at its output end. As these signals arc transferred onto bus 
3236, they are effectively input to the multiplexer 36. which, depending on the 
status of the logically positive programming enable signal IDEPEN, may then 
facilitate the multiplexing operation, in order to selectively connect a set of access 
signals onto the memory device 34. Under proper timing control, this set of 
relayed signals may either be used by the microcontroller 33 of the CD-ROM drive 
itself to operate the drive normally in the CD-ROM data reading sessions, or be 
used by the processor of the host computer system in the firmware upgrade session. 
Naturally, the semiconductor memory device 34 used in this case as the firmware 
storage in the CD-ROM drive must be one that is electrically reprogrammable. It 
can, for example, be an EEPROM, 

The above descriptive paragraphs have concentrated on the operation 
of the electronics of a CD-ROM drive constmcted in accordance with the teachings 
of the invention as it undergoes a firmware code upgrade operation in the memory 
device. On the other hand, it should be noted that, under normal situations, 
firmware code upgrade is a rare operation that can be expected less than several 
times in the lifetime of a CD-ROM drive. For most of the times, the CD-ROM 
drive yfiH be reading the memory contents of the CD-ROMs inserted into the drive. 
In this case, the progranmiing enable signal IDEPEN in the programming 
controller 32 of FIG. 4 maintains the connection of the memory, device 34 
substantially direct to the microcontroller 33, so diat the microcontroller 33 may 
execute the code in the memory device 34 to implement the CEKROM drive 
fimctionality. In this sense, a CD-ROM drive employing the apparatus of the 
invention is substantially the same as the conventional drives. 

Thus, as is illustrated in the block diagram of FIG. 3, the host computer 
system can implment its firmware-upgrade code-writing operation against the 
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mcmoiy device directly via the standard IDE bus 10. The programtning operation 
is executed by the host computer issuing instruction and related data via the bus 
lOA, and then via bus 3236 under control of the programming controller 32. The 
updated code is then sent over the memory device 34 via the bus 3436 as switched 
by the multiplexer 36. FIG. 5 details the circuitry configuration and the operation 
of a preferred embodiment of the muhipiexer 36. 

As is illustrated in FIG. 5, the multiplexer 36 that is employed in the 
block diagram of FIG. 3 has a group of five two-to-one multiplexer units 361, 362, 
363, 364 and 365. All five multiplexer units can be switched by the same control 
signal. In the case of the embodiment outlined in FIGS. 3 and 4, the programming 
enable signal IDEPEN is used as the control signal. All the five multiplexer units 
has their respective first set of input tied to bus 3336 and then to the microcontrol ler 
33 of the CD-ROM drive. The second set of input of the five multiplexer units are 
tied to bus 3236 and then to the IDE bus 10 via connection through the 
programming controller 32. The multiplexed output of the five multiplexer units 
are tied to bus 3436 and thus to the memory device 34. As is clearly outlined in the 
block diagram of FIG. 3, this bus connection arrangement allows the programming 
enable signal IDEPEN to facilitate the control of the memory device 34, which is to 
be selectively connected either to the microcontroller 33 for normal operation and 
to the drive IDE bus 1 0 for firmware upgrade operation. 

Note that the multiplexer unit 361 has a switched signal path width of 
16 bits to accommodate the need to relay the 16-bit lAO-1 5 signals that provide the 
address bits during the programming operation of the memory device 34. When 
the QD-ROM drive is operated normally, this 16-bit signal path width allows the 
connection of the 16-bit microcontroller address bits jiCAO-1 5 to be relayed to the 
16 address bits FAO-15 of the memory device 34. in a similar manner, the 
multiplexer unit 362 has an eight-bit width of switched signal path so as to 
accommodate the need to relay the two sets of data lines IHDO-7 and jxCDO-V onto 
the corresponding eight-bit data bus FDO-7 of the mcmoiy device 34. By contrast. 
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the multiplexer units 363, 364 and 365 are single-line multiplexing circuits thai can 
be used to relay the WE, CE and OE control signals of the memory device 34. 

Thus, with the ATA/IDE interface, a CD-ROM drive employing the 
app)aratus for on-side firmware code upgrade may be operated in one of two 
operation modes as the need arises. In the normal mode of operation, the firmware 
code memory device and the microcontFoUer of the CD-ROM drive can be 
connected together in order that the code in the memoiy can be accessed by the 
microcontroller to conduct normal CD-ROM operation. On the other hand, when 
the CD-ROM drive is put in the firmware upgrade mode, the memory device can be 
tied to the IDE interface of the drive, allowing the processor of the host computer to 
write directly into the addressed memory space of the memory device via the 
computer system bus that is tied to the IDE bus. The programming instruction code 
and the new code contents can be relayed to the memoiy device via the IDE 
interface equipped in the CD-ROM drive device. 

With this direct on-side programming capability, the CD-ROM drive 
employing the circuitry apparatus of the invention may enjoy the great 
convenienoe'of firmware code on-site upgrade operation. The drive itself need not 
be removed firom inside the computer system cabinet. The entire code-upgrading 
operation can be conducted fiiUy via software control With proper information 
provided, even the general end user may be able to conduct the upgrade operation 
by following detailed instructions shown, for example, on tfie display screen of the 
computer system. For the CD-ROM drive manufacturers, since both the upgrade 
software as well as the new version of the firmware program code may be made 
available to any requesting user via regular or electronic mail services, or via file 
transfer services in the public networks such as the Internet. Effective conservation 
of costs in both resource and time for both the manufacturer and the end user can be 
expected. 

Further, since the apparatus for implementmg on-site firmware code 
upgrade via the ATA/IDE interface for CD-ROM drives arc relatively simple in the 
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nature of the digital electronic circuitry employed, they can thus be integrated 
easily in the ASIC chipset of the drive circuitry. In fact, as is appreciable for 
persons skilled in the art, the inventive apparatus may, for example, be integrated 
in the CD-ROM decoder 31 of FIG. 3, or even in the microcontroller itself. 

While the invention has been described by way of example and in 
terms of preferred embodiment, it is to be understood that the invention need not be 
limited to the disclosed embodiments. On the contrary, it is intended to cover 
various modifications and similar arrangements included within the spirit of the 
appended claims, the scope of which should be accorded the broadest 
interpretation so as to encompass all such modifications and similar stnictures. 

4»Brief Explanation of the Drawinfj 

Other objects, features, and advantages of the present invention will 
become apparent by way of the following detailed description of the prefeircd but 
non-limiting embodiments. The description is made with reference to the 
accompanying drawings in which: 

FIG. 1 is a block diagram showing the electronic controller circuitry of 
a conventional CD-ROM drive; 

FIG. 2 shows the conventional interfacing connection, between the 
microcontroller, the firmware memory and the CD-ROM drive, decoder with 
respect to the drive IDE interfece that is typical in the CD-ROM drive of FIG. I; 

FIG. 3 shows the block diagram of the electronic controller circuitry of 
the CD-ROM drive employing the apparatus for on-site firmware code upgrade in 
accordance with a preferred embodiment of the invention; 

FIG. 4 shows the schematic diagram of the programming controller of 
the CD-ROM drive embodying the electronic circuit configuration of RG. 3; and 

FIG. 5 shows the schematic diagram of the multiplexer of CD-ROM 
drive embodying the electronic circuit configuration of FIG. 3. 
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An apparatus and the method for upgrading the firmware code of an 
optical disk drive via the ATA/IDE interface arc disclosed. The optical disk drive 
has a fimriware code memory and a microcontroller thai executes the firmware 
code. A drive decoder decodes to connect the optical disk drive to a host computer 
system via the ATA/IDE interface. The apparatus includes a programming 
conn-oiler that receives signals from the ATA/IDE interface and performs 
input/output decode determines whether the host computer system has requested 
for upgrade of the fimiware or for maintaining the optical disk drive in normal 
operation. A multiplexer has a first input connected to the programming conlTX)llcr. 
and the second input connected to the microcontroller. The multiplexer switches 
the first input to the memory device via the multiplexed output for performing a 
firmware upgrade operation when the host computer system requests for a 
firmware upgrade. The on-site upgrade operation can be perfomed without access 
to the inside of the drive unit. 

2. Representative Drawing 
F i g • 3 



